# Experiment 2 – Sequential Synthesis and FPGA Programming

Mehdi Jamalkhah, 810100111 Mobina Mehrazar, 810100216

Abstract— This document is a report for experiment #2 of Digital Logic Design Laboratory at ECE department, University of Tehran. The purpose of this experiment is to bridge the gap between programming software and programming hardware through designing and executing FPGA application.

#### Keywords -- Include at least 5 keywords or phrases

#### I. Introduction

The goal of this experiment is to introduce the concepts of state machines that are mostly used for controllers. The second goal is to get familiar with FPGA devices and implementation.

### II. SERIAL TRANSMITTER

A serial transmitter circuit is going to be designed that searches for a start sequence of 110101 on the serIn input and initiates transmission its serIn on its serOut. Upon detection of the start sequence, serOutValid is asserted, and the circuit transmits its serIn on its serOut for the next 10 clock cycles. After the entire 10 bits are transmitted, the circuit returns to its initial state, where it searches for the start sequence.



Fig. 1 Serial transmitter

# A. Onepulser

If the clk signal in a Verilog code is implemented using a push button that is manually triggered by a human, the circuit's behaviour will depend on the timing of the button presses and releases.

For example, if the circuit should receive a 010 sequence, the button must be pressed and then released after a clock cycle (i.e. 0.02 seconds), which may be impossible.

A One-Pulser is a solution to this problem which occurs in circuits where the input is received through a push button key.

The One-Pulser circuit is a simple digital circuit that generates a single pulse that synchronized with the system clock. By connecting the push button input to the One-Pulser circuit, we can ensure that the circuit generates a consistent clock pulse every time the button is pressed, regardless of the timing or duration of the button press.

The output of the One-Pulser circuit can be used for controlling the clock when the circuit is implemented on an FPGA board, by being connected to the clock enable input (clkEn) of the sequence detector and the counter.

1) The Verilog description of the One-Pulser module is shown in Fig. 2.

Fig. 2 One-Pulser Verilog description

The design was tested in ModelSim and shown in Fig.
 3.



Fig. 3 One-Pulser simulation: the circuit receives a signal that the button has been pushed and asserts single pulse signal (at cursor 1, 3, and 5). After a clock cycle, it returns to zero (at cursor 2, 4, and 6) to create a complete single pulse. (Note: the long pulse is active low and the single pulse is active high)

## B. Orthogonal Finite State Machine

An orthogonal finite state machine consists of a Moore state machine and a counter. When the clock Enable push-button is pressed, the Moore sequence detector checks its input and decides which state to transit. The sequence detector waits for the sequence of 110101 on its serIn input, and once received, the serOutValid output becomes one. The push button is pressed for every input that the state machine receives, after that the counter is enabled and counts for the next 10 consecutive clock cycles. During all these times, the serOutValid signal remains one.

1) The state diagram of the sequence detector is shown in Fig. 4.



Fig. 4 110101 sequence detector state machine

2) The top-level Verilog description of the transmitter circuit is shown in Fig. 5 and Fig. 6. This top-level description includes the Verilog description of the sequence detector and the Verilog description of the counter, which are interfaced together to form the complete transmitter circuit.

Fig. 5 Orthogonal finite state machine Verilog description (part 1)

```
always ((ps) begin
                              (rstCnt, incCnt, serOutValid) = 3'b0;
42
43
44
                                         'S5 : rstCnt = 1'bl;
                                        'S6 : {incCnt, serOutValid} = 2'bll;
default: (rstCnt, incCnt, serOutValid) = 3'b0;
48
49
50
51
52
53
54
55
56
56
66
67
68
69
70
72
73
      中中
                   always @(posedge clk, posedge rst) begin
                              if (rst) begin
ps <= '50;
                             end
                             else if (clkEn) begin
                                        ps <- ns;
                   always @(posedge clk, posedge rst) begin
                             if (rst) begin
countOut = 4'b0;
                             else if (clkEn) begin
if (rstCnt) begin
                                                  countOut = 4'b0110;
                                        else if (incCnt) begin
                                                   countOut = countOut + 1:
                   end
                    assign serOut = serIn;
```

Fig. 6 Orthogonal finite state machine Verilog description (part 2)

3) The result of simulation in ModelSim is shown in Fig. 7.



Fig. 7 Orthogonal finite state machine simulation: the state machine received 1, 1, 0, 1, 0, and 1 at cursor 1, 2, 3, 4, 5, and 6, respectively. Once the entire sequence of 110101 is detected the serOutValid signal becomes one (at cursor 6, same time as the last input is received) and after 10 clock cycles returns to zero (at cursor 7).

## C. Seven Segment Display

The output of the counter will be displayed on the seven-segment display of the FPGA board. Each seven-segment receives a four-bit input and displays the hexadecimal value on its 7-bit output (Fig. 8).



Fig. 8 Seven segment display

TABLE I SEVEN SEGMENT DISPLAY TRUTH TABLE

| decimal | B3 B2 B1 B0 | ABCDEFG |
|---------|-------------|---------|
| 0       | 0000        | 0000001 |
| 1       | 0001        | 1001111 |
| 2       | 0010        | 0010010 |
| 3       | 0011        | 0000110 |
| 4       | 0100        | 1001100 |
| 5       | 0101        | 0100100 |
| 6       | 0110        | 0100000 |
| 7       | 0111        | 0001111 |
| 8       | 1000        | 0000000 |
| 9       | 1001        | 0000100 |
| 10      | 1010        | 0001000 |
| 11      | 1011        | 1100000 |

| 12 | 1100 | 0110001 |
|----|------|---------|
| 13 | 1101 | 1000010 |
| 14 | 1110 | 0110000 |
| 15 | 1111 | 0111000 |

1) Verilog description of the seven-segment display module is shown in Fig. 9 which is written based on table 1.



Fig. 9 Seven segment display Verilog description

2) The result of simulation in ModelSim is shown in Fig. 7.



Fig. 10 Seven segment display simulation

#### III. SERIAL TRANSMITTER IMPLEMENTATION

A top-level Verilog description was created for the implementation of a design using the DE1 development board. The description includes all three parts, namely the One-Pulser, sequence detector, and seven-segment display modules, connected together (Fig. 11).

```
timescale fandins

module SerialTransmitter(clk, rst, clkPB, serIm, seg0, serOut, serOutValid);

imput clk, rst, clkPB, serIm;

output (6:0) seg0;

output (6:0) seg0;

vire clkRen;

wire [1:0] countOut;

OmePulser compeller (.clk(clk), .rst(rst), .longPulse(clkPB), .singlePulse(clkEm));

OmePulser compeller (.clk(clk), .rst(rst), .longPulse(clkPB), .singlePulse(clkEm));

OmePulser compeller (.clk(clk), .rst(rst), .serIm(serIm), .clkEm(clkTm),

.countOut (countOut), .sep0(seg0));

omerandule

orthodole
```

Fig. 11 Serial transmitter Verilog description

The result of Serial transmitter simulation in ModelSim is shown below:



Fig. 12 Serial transmitter simulation

To see more details, the waveform is presented in two part below:



Fig. 13 Serial transmitter simulation (part 1): the circuit received 1, 1, 0, 1, 0, and 1 at cursor 1, 2, 3, 4, 5, and 6, respectively. Once the entire sequence of 110101 is detected the serOutValid signal becomes one (at cursor 6, same time as the last input is received).



Fig. 14 Serial transmitter simulation (part2): after 10 clock cycles serOutValid signal returns to zero (at cursor 6). During this time, the counter counted from 6 to 15 and the seg0 shows its seven-segment display.

The DE1 development board was used as the hardware platform for the implementation of the design. This board provides a convenient and reliable platform for testing and verifying the functionality of the design in a real-world setting.

First, we created a Quartus project and added the top-level Verilog code to the project. After successfully compiling the design, we assigned physical pins on the Cyclone II FPGA on the DE1 board for the design. We selected the push-buttons to be used as serIn and one-pulser inputs, and determined which LEDs to use for displaying serOutValid and serOut. We then consulted the DE1 user manual to identify the position and index of each pin.

The completed pin planner window is shown in Fig. 15 which Connections are set according to table 2.

TABLE II PIN ASSIGNMENTS

| Signal Name | FPGA Signal | FPGA Pin No. |
|-------------|-------------|--------------|
|             | Name        |              |
| seg0        | HEX0        | -            |
| clk         | CLOCK_50    | PIN_L1       |
| clkPB       | KEY[0]      | PIN R22      |
| rst         | SW[9]       | PIN L2       |
| serIn       | SW[0]       | PIN_L22      |
| serOutValid | LEDG[0]     | PIN_U22      |
| serOut      | LEDR[0]     | PIN R20      |



Fig. 15 Pin planner window



Fig. 16 A Cyclone II board with serial transmitter programmed using Quartus: Red LED(LEDR0): it shows serOut which is one at this moment as we wanted because serIn(SW0) is one. Grean LED(LEDG0): it shows serOutValid which is one at this moment, because the sequence has detected and counter output is 15 (i.e. 10 clock cycles have not passed yet). HEX0: it shows counter output.

The chip planner of each modules are Shown below which provides a visual display of device resources.



Fig. 17 Serial transmitter chip planner



Fig. 18 One-pulser chip planner



Fig. 19 Orthogonal finite state machine chip planner



Fig. 20 Seven segment display chip planner

### IV. Conclusions

# ACKNOWLEDGMENT

This report was prepared and developed by Mehdi Jamalkhah and Mobina Mehrazar, bachelor students of Computer engineering at University of Tehran, under the supervision of professor Zain Navabi.

## REFERENCES